// pages/recommendSong/recommendSong.js
import PubSub from 'pubsub-js'
import request from '../../../utils/request'
Page({

  /**
   * 页面的初始数据
   */
  data: {
    month: '',
    day: '',
    //推荐歌曲列表
    recommendList: [],
    //点击音乐详情下表
    index:0
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    //获取日历的月份和日份
    this.setData({
      month: new Date().getMonth()+1,
      day: new Date().getDate()
    })

    //判断用户是否登录，如果没有登录就不必要尽心下面操作
    let userInfo = wx.getStorageInfoSync('userInfo')
    if (userInfo.keys.length==0) {
      wx.showToast({
        title: '请先登录',
        icon: 'none',
        success:() => {
          //跳转至登录界面
          wx.reLaunch({
            url: '/pages/login/login',
          })
        }
      })
    }
    this.getRecommendList();

    //订阅来自songDetail页面发布的消息
    PubSub.subscribe("switchType", (msg, type) => {
      let { recommendList,index } = this.data;
      if (type === 'pre') {
        //上一首
        (index===0)&&(index=recommendList.length)
        index -=1
      } else {
        //下一首
        (index === recommendList.length-1)&&(index=-1)
        index +=1
      }

      this.setData({
        index
      })

      let musicId = recommendList[index].id
      //将id回传
      PubSub.publish('musicId',musicId)
    })
  },


  async getRecommendList() {
    const recommendListData = await request('/recommend/songs')
    this.setData({
      recommendList:recommendListData.recommend
    })
  },

  // 路由跳转到播放界面
  toSongDetail(event) {
    let { song, index } = event.currentTarget.dataset;
    this.setData({
      index
    })
    wx.navigateTo({
      url: '/songPackage/pages/songDetail/songDetail?musicId='+song.id,
    })
  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})